Fork me on GitHub

一串奇怪的数

题目

请解密密文得到该产品的密钥(最后一组密钥即为key)

题目链接

http://www.shiyanbar.com/ctf/1824

题解

下载txt文件,改ZIP文件,解压得到两个文件 一个是加密算法的python代码 一个是问题描述

看懂加密过程之后写解密程序,最关键的是加密密码 这里为空。

encode

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#coding:utf-8
import hashlib
def md5(s):
return hashlib.md5(s).hexdigest()
def evalCrossTotal(strMd5):
r = 0
for i in strMd5:
r += int("0x%s" % i, 16)
return r
def encryptString(strString, strPasswd):
strPasswdMd5 = md5(strPasswd)
intMd5 = evalCrossTotal(strPasswdMd5)
r = []
for i in range(len(strString)):
r.append(
ord(strString[i]) + \
int("0x%s" % strPasswdMd5[i%32], 16) - \
intMd5
)
intMd5 = evalCrossTotal(
md5(strString[:(i+1)])[:16] + \
md5(str(intMd5))[:16]
)
return " ".join(map(lambda x: str(x), r))

miaoshu.txt

1
2
3
4
5
6
7
8
9
10
11
12
13
题目描述:给你一串密文, 它的加密代码(附件中)也已经截取, 现得知解密后是某产品的密钥. 下面是密文内容:
-149 -234 -157 -132 -187 -140 -157 -241 -158 -177 -85 -215 -180 -187 -173 -218 -161 -183 -133 -226 -136 -171 -126 -169 -155 -96 -169 -240 -163 -153 -137 -111 -123 -191 -151 -213 -151 -142 -152 -208 -118 -137 -136 -244 -157 -168 -187 -201 -170 -176 -192 -209 -205 -174 -163 -189 -126 -133 -148 -194 -145 -212 -170 -155 -148 -165 -167 -206 -171 -177 -88 -173 -125 -129 -129 -235 -121 -190 -161 -165
下面是该产品一些公开的密钥:
T5Q-4HQ-KEY-KP0-HAH
FCK-MNO-KEY-O8W-HAH
MRS-L1H-KEY-FU3-HAH
ICR-AAA-KEY-BBB-HAH

最后解密代码为:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#coding:utf-8
import hashlib
def md5(s):
return hashlib.md5(s).hexdigest()
def evalCrossTotal(strMd5):
r = 0
for i in strMd5:
r += int("0x%s" % i, 16)
return r
def encryptString(strString, strPasswd):
strPasswdMd5 = md5(strPasswd)
intMd5 = evalCrossTotal(strPasswdMd5)
r = []
for i in range(len(strString)):
r.append(
ord(strString[i]) + \
int("0x%s" % strPasswdMd5[i%32], 16) - \
intMd5
)
intMd5 = evalCrossTotal(
md5(strString[:(i+1)])[:16] + \
md5(str(intMd5))[:16]
)
return " ".join(map(lambda x: str(x), r))
#以下就是自己写的
def decryptString(nList,strPasswd):
strPasswdMd5 = md5(strPasswd.encode("utf8"))
intMd5 = evalCrossTotal(strPasswdMd5)
r = ""
for i in range(len(nList)):
r+=chr(nList[i] - int("0x%s" % strPasswdMd5[i%32], 16) + intMd5)
intMd5 = evalCrossTotal(md5((r[:(i+1)]).encode("utf8"))[:16] + md5((str(intMd5)).encode("utf8"))[:16])
return r
def foo():
s="-149 -234 -157 -132 -187 -140 -157 -241 -158 -177 -85 -215 -180 -187 -173 -218 -161 -183 -133 -226 -136 -171 -126 -169 -155 -96 -169 -240 -163 -153 -137 -111 -123 -191 -151 -213 -151 -142 -152 -208 -118 -137 -136 -244 -157 -168 -187 -201 -170 -176 -192 -209 -205 -174 -163 -189 -126 -133 -148 -194 -145 -212 -170 -155 -148 -165 -167 -206 -171 -177 -88 -173 -125 -129 -129 -235 -121 -190 -161 -165"
nList=eval('[%s]' %s.replace(' ',','))
strPasswd='' #密码为空
print(decryptString(nList,strPasswd))
if __name__ == '__main__':
foo()
print("ok")
pass

得到的结果为:

D:\home_for_python\python.exe D:/workspace/cipher/strange_characters.py
T3A-BED-KEY-78B-HAH
CER-TYH-KEY-FOP-HAH
WER-84R-KEY-982-HAH
SEC-URI-KEY-TYB-HAH

ok

-------------本文结束感谢您的阅读-------------